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@ Data compression/decompression and storage of compressed and uncompressed data on a single 
data storage volume. 


(§) A data f3e having a plurality of data blocks is 
divided into one or more transfer units of data 
biodcs. Before data storage, each transfer unit 
of data blodcs is subjected to its own data 
compression cyde to create a group of com- 
pressed data \Aocks, The size of the data trans- 
fer unit, in bytes. Is selected to t>e facie for 
addressing and retrieving irnlrvidual recorded 
groups of compressed data bfodcs whHe provid- 
ing good channel utilization and compression 
eflidency. Also the data-transfer unit size Is 
selected in part based upon data storage efl>- 
den^f, i.e. the storage of the compressed data 
should f3l as many addressat)le data storage 
areas as possible. Upon recording each group 
of compressed data bytes, an entry is made into 
a file directory for enabling addressing the re- 
corded corhpressed data k>locl<s. 
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BLOCKS 


OTU OF DATA BLOCKS IS 
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STORAGE SYSTEM 
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DATA BLOCKS a RECORDS 

THE GROUP AS ONE 
CONHNUUM OF DATA 


DATA STORAGE SYSTEM 
SENDS DETAILED STATUS TO 
HOSTPROCCSSOR AS TO THE: 
RECORDING OF THE GROUP 
OF COMPRESSED DATA 
BLOCKS 
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RELD OF THE INVENTION 

This Invention relates to data storage systems that are capable of storing tx)th compressed and uncom- 
pressed data on one data storage volume and to data processing systenns utilizing such data storage systems. 
This invention also relates to data storage systems that minimize wasted data storage space on a data storage 
volume whQe storing compressed data. 

BACKGROUND OF THE INVEhmON 

Many data storage nrtedia, such as data storage optical disks, have a so-called fixed Irfock architecture 
(FBA) formal Such format is characterized in an optical disk by so-called hard sectoring the disk's single spiral 
track Into a plurality of sectors. Everyone of the sectors have identical data storage capacity, i.e. 512 bytes. 
1 024 bytes. 4096 bytes, eta Because of the FBA disks and the variability of data lengths of compressed data 
with respect to the source uncompressed data, in-line data compression has not been employed with FBAfor- 
nr^atted disks. It is desired to ef f icientiy store and enable simple random address accessing of a variable amount 
of compressed data resulting frxHn compressing data whteh has been formatted Into addressable btocks. Such 
compressed data can then be recorded on a FBA formatted disk, lif the sector data does not compress to fewer 
bytes, then the data are stored without data compresston on the data storage disk. 

It is also desired when a plurality of addressable data blocks is segmented into a plurality of groups of such 
data blocks, to maintain host processor addressability of the compressed data blocks within each compressed 
group of data blocks. It is also desired when compressing data for storage on a FBA storage medium to maintain 
a maximal addressability of all unused data storing sectors even though the number of sectors required to store 
the compressed data blocks is unknown. A further desire is to provide for random addressing of the com- 
pressed data blocks recorded in an FBA formatted storage medium. 

The data pattern randomness of most input date streams and the variability in the resulting length of the 
compressed date output after the applicatton erf the various compresston algorithms, does not allow for the 
prediction of the amount of storage space required to contain the compressed date. Thfe situatfon requires a 
link between the transmission of the date stream to be compressed and recorded and the resulte of the com- 
pression process to assist the host processor in ite storage management process. 

The functton of updating a date file in this environment can not use any usual date updating process (read, 
update, write back) because the date pattern as a result of the update niay not compress to the same degree 
as the original date block and therefore updated compressed date most probably wDI not fit In the original stor- 
age space required to store the original date. 

In afixed block architecture (FBA) environment, date are recorded on a date storage medium in fixed sized 
unite of storage called sectors where each recording track on the riiedium conteins a f bced number of such sec- 
tors. The addressing conventton for optk:al disk devk»s consists of a track address on the medium and a sector 
number of the particular track On optfcal media storage devices, each of the sectors consists of two major 
parte; an Identification field (ID) used by the device controller to locate a particular sector by a physical address 
and a date field for storing data The informational content of the ID's on hard sectored optical disks are indelibly 
recorded, as by a stamping/nrK)lding process, on the medium at the time of manufecture. Other date storage 
formate also are usable to practice the present invention, such as the known count-key-date (CKD) and ex- 
tended count-key-date (ECKD) formate used on many magnetic disk nriedia. 

An FBA device atteched to a host via the known Small Computer Standard Interfece (SCSI) must provkle 
the capability to rescue a Logical Block Address (LBA) used by SCSI architected direct-access date storage 
devk^es to address fUed sized unite of storage to a unique physk:al address (track and sector) on the medium. 
The SCSI atteched FBA device provkies to the host a contiguous address space of N (N is a positive integer) 
storage locations which can be accessed for reading or writing in any sequence. Each 13A directory structure 
(addresses ranging from 0 to N) is the addressing mechanism used to store and retrieve date blocks in the 
SCSI-FBA environment (some FBA devices also provkle the capability to address the storage space using the 
physteal address). 

As can be seen from the preceding paragraphs, the principal problem facing a designer of a storage system 
using date compression techniques in the SCSI-FBA environment is to provkle a mechanism by which fixed 
size unite of date, herein termed date bk)cks. in an Input date stream can be recorded In a variable wiount of 
storage medium space and sfall nnaintain addressabiity to the unoccupied storage space and provkle for ad- 
dressability to the recorded date blocks. 

Since many optical disks today are of the refr>ovable type, it is further desired to enable each removable 
date storage medium to be self-describing as to compressed and uncompressed data held thereon. 
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DISCUSSION OF THE PRIOR ART 

The Vosacek US patent 4,499,539 shows first allocating a number of data storage segments of a cache 
or bufferfor storing a maximum number of data bytes that are storable in an addressable track of a direct access 

5 storage device (DASD) connected to the cache or buffer. The DASD is a magnetic disk storage device. The 
protocol is to stage or transfer one track of DASD data to the cache or buffer in one input-output operation 
(one access to the DASD). Upon completion of the actual data transfer, the cache or buffer is examined. If 
less than all of the first alk>cated segments contain data, then the empty allocated segments are deallocatBd. 
Pointers are recorded in a first one of the allocated segments for pointing to additional allocated segments that 

10 store data from the same DASD track- In this manner the DASD b^ck is emulated in the cache or buffer. 

US Patent No 5097261 (application No USSN 07/441 .126) shows a data compactkwi system for a magnetk: 
tape peripheral data storage system. Tapes do not have any addressable data storage areas. The entire tape 
is formatted each time it is recorded. This formatting feature In magnetic tapes enables storing variably sized 
records as variably sized blocks of data. The storage of uncompressed and compressed data is by addressable 

IS blocks of such data. The application does show including a plurality of records in one t>lock of data recorded 
on the tape. Co-pending commonly-assigned US patent application USSN 07/372.744. fled 6y28/89,(Attorney 
docket TU989003) shows a magnetk: tape data storage system that automatically stores a plurality of small 
records in each block of recorded data. Each of the records remah faidividuaily addressable. A purpose of cono- 
blning a plurality of records In one block is to reduce the number of inter-block gaps for Increasing the storage 

20 capacity of the magnetic tape. 

Data compression and decompression algorithms and systems are weU known. US patent 51 09226 shows 
an in line (real time) data compiBssion/decompression system for use in high speed data channels. This system 
uses an algorithm shown in the Langdon, Jr. et al US patent 4,467.317. Batch processed (software) data conv 
pression and decompression is also well knovm. PKWARE, Inc., 7032 Ardara Avenue. Glendale Wl 53209 USA 

25 provides the software programs PKZIP for batch compressk>n, PKUNZIP for batch decompression among 
other compressbn-decompression software. Another data compresstorMieoompression algorithm has been 
used for both batch (software processing) and In-line (hardware-rntegrated semiconductor chips) processing. 
The known Lempel Ziv-1 data compressfon/decompression algorithm is used for both in-line (real time) and 
batch data compresston and decompression. It is preferred to use the latter algorithm. Shah and Johnson in 

30 the article DATA COMPRESSOR DECOMPRESSOR IC in the "1990 IEEE International Symposium on Cir- 
cuits and Systems. New Orleans LA USA (pp 41-43) on May 1-3. 1990 describe an integrated circuit using the 
known Lempel-Ziv algorithm mentioned atx>ve. In practidng the present invention, it is preferred that a conD- 
pression-decompressbn algorithm that fadlitates both batch and in line operations be used. Of course, only 
batch or only in line data oompressfon-decompresston may be used to successfully practice the present in- 

35 vention. 

Images or 'non-coded* data have been compressed and decompressed for saving data storage space. 
Reitsma US patent 4.622,585 shows one vkJeo compressk>n scheme. 

SUMMARY OF THE INVENTION 

40 

The present invention provides flexible data compresston-decompresston controls that enable randomly 
accessing compressed data through relatively simple accessing mechanisms. 

According to a first aspect, the present invention provkies apparatus for storing data in compressed form 
in a data storage device having a plurality of addressable like-sized data storage areas, each for recording a 

45 predetermined number of data bytes, the data storage device being connected to means for receiving dato to 
be recorded, sakf received data being arranged in a plurality of addressable data blocks, characterised in that 
the apparatus comprises, in combination: selection means in the means for receiving data for selecting one 
or rrxMB data transfer units of data blocks to t>e recorded, each said transfer unit of data blocks having a given 
number of data bytes and including one or more of said addressable data blocks; compression means con- 

so nected to the selection means for compressing saki transfer unit of data blocks to be recorded as a group of 
compressed data blocks; data access means in the device connected to said compressfon means for recording^ 
said group of compressed data bk>cks in saki addressable data storage areas as one continuum of compressed 
data; and directory means indicating which ones of said addressable data storage areas saki continuum of data 
is recorded in, and indk^ting that saijd continuum of dato conteins said selected transfer unit of dato bbcks in 
a compressed form. 

In a second aspect of the present inventfon there is provided a method of compressing and recording onto . 
a date storage medium date of a file which is arranged in a plurality of addressat)le date t>tocks, the method 
comprising the steps ot selecting a pluralfty of saki date blocks of saki file to be compressed and recorded; 

3 . 
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segmenting the selected plurality of addressat)le data k)locks Into one or more data transfer unKs; compressing 
each of said one or more data transfer units and recording them as respective separate groups of compressed 
data t>locks; and creating and maintaining a file directory indicating the address and size of each of said re- 
corded groups for enabling random access to recorded data within said file of data blocks. 

5 Preferably, the file directory provides infornnation for addressing each of the compressed data blocks with- 

in a group, it is further preferred that the directory is maintained in a host processor and is also stored on the 
data storage medium containing the group of compressed data blocks. 

In a preferred embodiment of the present Invention, a datafOe having a plurality of addressable data blocks 
is segmented into a plurality of groups of such data blocks. Each group of data blocks is separately compressed 

10 and decompressed as one unit of data. Each such group is separately transmitted between a host processor 
and a data storage unit, communteattons link, etc as one data transfer unit (DTU). The size of the DTU, In terms 
of the number of data blocks to be included, is determined empirically based upon the data storage capacity 
of (number of data bytes storable in) sectors into whk:h a data storage volume is divided, the number of bytes 
in each of the data blocks of the data file, and other system parameters. The data storage of each group in 

1$ compressed form in a data storage device is described by the data storage system to the host processor, pre- 
fBrabiy by a command linked to the.host processor command effecting the data storage in compressed form. 
The host processor establishes a directory describing the storage of each and every group of the data fife. If 
the data file is transferred to another system or host processor In the compressed form, the compressed data 
f ae directory accompanies the compressed groups. Retrieving compressed data from a data storage device 

20 is by ratrieving the group of data blocks having the data block(s) desired to be read. Each compressed group 
of data blocks is transferrable between host processora and data storage units without deoompresston. The 
DTU or group>receivlng data storage medium may be formatted In the well known fixed-block architecture 
(FBA) format, the well known count-key-data (CKD) format, the well known extended count-key-data (ECKD) 
fornr^t or any other format 

25 Embodiments of the present invention will now be described in more detaS, with reference to the accom- 
panying drawings in which: 

Fig. 1 is a flow chart illustrating data storing operations according to an embodiment of the present inven- 
tion; 

F^. 2 is a simplified block diagram of a data processing system in which the data storing operattons aq- 
30 cording to Fig. 1 may be advantageously employed; 

Fig. 3 is a diagrammatic representation of a Logical Block Address (LBA) directory for kientif ying recorded 
compressed groups of data blocks of a data file; 

Fig. 4 is a block diagram showing details of an optk^al data storage system attached to a host processor 
such as is shown in Fig. 2; 

35 F'g. 5 is a block diagram of a peripheral controller usable. in data processing systems such as are shown 
in Fig's 2 and 4; 

Fig. 6 diagrammattealty illustrates storing a compressed group of data blocks according to the steps of Fig. 
1; 

Fig. 7 diagrammatically illustrates host processor commands using a SCSI connectkm to a data storage 
40 system such as is shown in Fig. 2 or Rg. 4; 

Fig. 8A diagrammatteally illustrates a file directory of a plurality of compressed groups of data Mocks of a 
file according to an embodiment of the present inventfon; 

Fig. 8B diagrammatically Slustrates the format of a disk sector according to an embodiment of the present 
invention; 

45 Fig's 9-13 are flow charts showing detais of the operatnn shown in Fig. 1; 

Fig. 14 is a logic diagram aiustrating an applk:atk>n of the present inventton to a multi-unit data processing 
system that has a plurality of data storage devices and host processors interconnected by a data link or 
local area network; and 

Fig. 15 is a flow chart showing nnachine operations that update a compressed data file according to an 
50 embodiment of the present invention. 

DETAII^D DESCRIFnON 

Referring now more partknilariy to the appended drawings, like numerals indicate like parts and structural 
55 features in the various figures. A data file having a plurality of data blocks is divided into one or more transfer 
units of data blocks. Before data storage, each transfer unit of data blocks is subjected to its own data com- 
pression cycle to create a group of compressed data blocks. The size of the data transfer unit, in bytes, is se- 
lected to be facile for addressing and retrieving individual recorded groups of compressed data tHodks while- 
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providing good channel utilization and compression effidency. Also the data transfer unit size is selected in 
part based upon data storage eff iciency, i.e. the storage of the data, after compression, should fill several a^ 
located addressat)le data storage areas. Each of the allocated sectors in each group is filled to capacity except 
the last sector of a group that may be partially filled. It is deso^ to reduce the number of partially f flied data 
5 storage sectors for more efficiently filling the FBA data storage disk with data. This desire is balanced with 
enabling efficient random access to the compressed data blocks stored on the FBA date storage disk. 

Each stored or recorded group of compressed data blocks is accessed from disk 30 as a single data unit 
Irrespectiva of the number of disk 30 sectora in which the group is recorded. Since each group of compressed 
data blocks ^ compressed in a separate data compression operatton, all of the dato in each such group must 
10 be decompressed starting with the beginning, i.e. first compressed bytes, in each group. Therefore, in randomly 
accessing a compressed desired data block in a given group, ail of the compressed data blocks of each stored 
group are read from disk 30 as a single disk record. The single disk rclcord is decompressed up to the desired 
or addressed compressed dato block. The desired compressed data block is then decompressed for process- 
ing. Limiting the s^ of the groups of compressed data blocks provides for qufcker access to any desired com- 
15 pressed dato block. This desire is balanced with a desire to maximize utilizatnn of the disk 30 dato storage 
space. An example of managing these two parameters for creating a facie size group of compressed dato 
blocks (that varies with each application) is described later. 

In an alternate arrangement, each date block is separately compressed. A plurality of such separately com- 
pressed dato bk)cks are combined into a single disk record. The byte position within the single disk record for 
20 each of the separately compressed date blocks is recorded in the single disk record. Such byte position or offset 
enables addressirig each of the compressed dato blocks within a group. 

To factlitete access to the groups of compressed date blocks, the host processor program maintains a di- 
rectory that kfentiftes the addressable date storage areas conteining the group as well as the date blocks in 
the respective groups. This directory klentificatkjn preferably takes the form of a file directory that is main- 
25 teined in host processor 11 . Such directory is also stored on the volume or date storage disk containing the 
group(s) of compressed date blocks. Pr^erably. the directory is transmitted to the disk device as a part of each 
transfer of a compressed file having plural groups of compressed date btocks. This arrangement establishes 
on the FBA disk a directory that effects addressability of the compressed date blocks within the respective 
groups. 

30 f 1 Qiustrates recording a dato file by grouping a plurality of dato blocks of the file into a smaller number 
of groups of compressed dato blocks. Stop 10 is executed in a host processor 11 (Fig. 2). A date fOe. or part 
of a date file, is identified for compressed date storage. The date file consists of a plurality of date blocks. The 
term dato block includes date records (coded dato), sub>f ile structures, individual images, graphs and the lice, 
drawings and other foriTis of graphics, conibffied graphks (non-coded date) and text(coded date), and the lice. 
35 As later deteied. the date file is divided into tocfle sized groups of dato blocks for transfer as a data transfer 
unit DTU to a storage unit or over a communication link and for maintaining a random access capability to the 
recorded groups of compressed date blocks. The size of each DTU and resultentrecorded group is dependent 
on diverse variables, as will become apparent Completion of one executfon of step 1 0 resulte in one such group 
of date t>locks being selected for compression and storage. 
40 Step 13 is executed by host processor 11 (Fig. 2). The number of uncompressed date bytes in the DTU of 
dato blocks (the product of the number of dato blocks times the number of bytes in each dato block) is divided 
by the date storage capacity of one addressable data storage area (sector of an FBAformatted disk) and round- 
ed to a next higher integer if the product includes a fraction. This number represente a maximum number of 
addressable dato storage areas required to store the data; either uncompressed or if a compresston does not 
45 compress the dato into fewer bytes for storage. At this junctore, it is not knowin how rnany addressable data 
storage areas are required to store the group of dato blocks after compresston. To ensure that the group of 
data blocks is storable on the data storage medium (optical disk 30 is used in the illustrative embodiment), a 
number of the addressable date storage areas sufficient to store the entire group of compressed dato blocks . 
is initially determined for storing the group of dato blocks in an uncompressed form. 
50 Stop 15 is executed by both the host processor 1 1 and data storage system 12. The selected DTU of data 
blocks is transmitted by the host processor to the data storage system. The data compression of the selected 
DTU of data blocks is compressed before storage on the dato storage medium 30 (F^. 4). There are several 
methodologies that may be employed herein. The Fig. 1 indk:ated methodofogy requires the dato storage sys- 
tom to allocato the maximum number of addressable date storage areas. Then the dato transfer occura requir- 
es ing the date storage system to compress the selected DTU of dato blocks just before the dato are recorded 
on the data storage medium 30 (Fig. 4). Upon completion of the compression and dato storage or recording 
as one continuum of dato, date storage system 12 determines the number of addressable dato storage areas 
actoallyusedtostorethecompressedgroupofdato blocks. The unused butallocated addressable dato storage 
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areas are then deallocated. In the event that certain data blocks compress to a greater numt>er of bytes than 
the original or uncompressed data, then, as will become apparent, the data compression step is not used. Con- 
trol data are recorded on the FBAdisk that indicates whteh data are compressed and which data are not conv 
pressed. Such control data are used In retrieving data from the data storage (FBA) disk, as will become appa- 

5 rent As later detailed in this specification, at step 16 data storage system 12 sends the storage tocatk)ns of 
the just-recorded group of compressed data blocks to the host processor 11 for inclusion in a directory of the 
data file to which the recorded group of data blocks is a member. 

A second ntethodology has the data compressk>n-deoompressk)n performed In host processor 11. As 
such, host processor 11 includes the data compression mechanism, either software or hardware, and sends 

10 the compressed selected group of data blocks to data storage system 12 for storage. In ths instance, if batch 
compresston Is used, host processor determines the number of addressable data storage areas required for 
storing the compressed group of data blocks. Host processor 11 then sends the required number of address- 
able data storage areas to data storage system 12 for allocation just before the compressed data are trans- 
mitted to the data storage system. 

IS In a third methodology, the uncompressed group of data blocks are transmitted twice by host processor 
11 to data storage system 12. A first transmissk>n enables data storage system 12 to accurately nneasure the 
. number of addressable data storage areas that wiD be required to store the compressed data. In the first trans- 
mlsston the data are compressed but not recorded. The number of compressed data bytes are counted to de- 
termine the data storage extent (numt>er of sectors or addressat)le areas) for the compressed data. The data 

20 storage system 1 2 then allocates the Indicated number of contiguous sectors for receiving and storing the com- 
pressed data. Asecond transmlsston of the same data tothe data storage system 12 results In the compression 
and storage of the compressed data in a data storage medium. 

In each of the above descrit>ed methodologies. If the number of bytes in the compressed file is greater 
than the number of uncompressed data bytes, then the date are recorded in the uncompressed form. Further, 

25 when updating a group of compressed date blocks, the number of compressed data bytes may exceed the 
capacity of the currently allocated sectors. As described later with respect to Fig. 15, a change in allocation 
of sectors for storing the updating DTU may be required. 

. Also, in each of the above described methodologies, the data blocks to be compressed and stored from 
each DTU are preferably compressed and stored as one group. That is, all data blocks in each DTU are conrv 

30 pressed during one data compresston cycle to produce one group of compressed data blocks. An alternate 
date compression approach is to individually compress each of the date btocks In each DTU. Then the group 
of compressed date blocks cbnsiste of a plurality of individually compressed data btocks. In the alternative date 
compression, a header in each group can Mentify the byte offset within each group of the individually com- 
pressed data blocks. Such indivkiually compressed date bk>cks may also be kJentified on the data recording 

35 disk by fliegal recording code characters, such characters are well known for diverse data recording codes. 

Host processor 11 In step 19 logk»lly associates all recorded groups of compressed data blocks via a later 
descrit)ed file directory. When employing the at)ove descrit>ed first methodotogy, upon storing the compressed 
data, data storage system 1 2 reporte to host processor 1 1 the actual number of sectors used to store the conv 
pressed data and further address and kientifying data therefore, as will be described. 

40 At step 20, host processor 11 determines whether all of the date to t>e compressed and recorded have 
been recorded. The deteils regarding the recorded group of compressed date blocks (see step 1 9) have been 
entered into the later described file directory (Fig. 8A). if all of the above descrit>ed machine operations have 
t>een completed, then the operatk)n is 'done', enabling exiting to other machine operations t)eyond the present 
description. Otherwise, steps 10-19 are repeated as at>ove descrit>ed untO all of the date have been conv 

45 pressed and recorded. It is to be noted that other machine operations may be performed by host processor 
11 in a multi-tesking or interrupt driven date processing environment whHe steps 10-19 are in the process of 
execution as is known in the date processing art 

Fig. 2 shows a date processing system in simplified form. Host processor 11 attaches a data storage sys- 
tem 12. Data storage system 12 includes a peripheral control 20 that connects host processor 11 to data storage 

so device 21. Device 21, In one embodiment of this Invention, is a magneto-optical data storage device that op- 
erates with removable magneto-optical data storage media or a single medium (disk). As later used in this spec- 
ification, the term programmed machine includes host processor 11 , peripheral controller 20 and programmed 
portions of data storage device 21 . The compressk^n-decompressbn niechanisms are preferably in the pro- 
grammed machine. For in-line compressk>n-decompresston, it Is preferred that the compresskMvdeoompres- 

S5 sion occurs in the peripheral controller 20. As later described with respect to Fig. 14, the tocatton of the conv~ 

presslon-decompressbn mechanism can be anywhere in the programmed machine. For batch compresston- 
deconripression it is preferred to place the compression-decompressbn in host processor 11. 

Fig. 3 illustrates a logical block address (LBA) structore 23 used in m^netcvoptical disk data storage sys- 
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terns for addressing sectors of an optical disk. L3A 23 Is a logical to real address translation mechanism that 
enables full advantage of practicing the present invention. This sector addressing is based upon the logical 
addressing found in many present day optica! disk data storage devices. The attaching host processor 11 ad- 
dresses data on disk 30 (Fig. 4) using a logfcal block address included In LBA23. LBA23 determines which 
5 of the addressable physical data storage addressable areas, such as sectors, are addressed by the respective 
LBA address. In an alternate addressing arrangeiifient, host processor 11 requests access to a named file. This 
alternate addressing arrangement includes host processor 11 klentifying byte location within the file to begin 
a data operation and a number of bytes (byte length) to be subjected to the data operationp i.e. riead from the 
disk, for example. 

10 LBA 23 is managed by either one of two algorithms. A first one has been used for optical disks. In this 
algorithm, the number of entries in LBA 23 is constant for each disk and is based upon the number of address- 
able entities in the disk designated for storing data. Spare addressable data storage areas or sectors are not 
included in the LBA 23 logical address sequence, as is known. Known secondary pointers enable addressing 
spare sectors via LBA 23. 

15 A second algorithm for addressing using LBA 23 is used In magnetic fl^ble diskettes. In this second al- 
gorithm, the address range of LBA 23 varies with the number of demarked or unusable sectors. LBA 23 kJerv 
tifles for addressing only the tracks and sectors that are designated for storing data. In the event one of the 
sectors kJentiflable by the Illustrated address translatton becomes unusable, then the unusable or defective 
sector is skipped and replaced by another sector. Such substitutton is well known. 

20 All of the addressable tracks and sectors on disk 30 are addressed via LBA23. Such addressing is a table 
look up matching the host processor 11 supplied logical address to a physical disk track and sector storing the 
data identified by the supplied logical address. Each LBA logical address has one entry 14 in LBA 23. 

Numerals 17 and 18 indicate groups of compressed data blocks recorded on disk 30 using the present 
invention. Numeral 17 Indfcates the first group of compressed data blocks of one file. Numeral 18 indicates 

25 subsequentiy recorded groups of compressed data blocks from the same file. The enumeration of the data 
blocks in the recorded groups 17-18 is maintained in its original sequence as generated by host processor 11. 
As will become apparent, the compressed data blocks in the respective groups are identified in a file directory 
shown in Fig. 8A. 

A magneto-optic data storage drive or device 21 is illustrated in Rg. 4 as it is connected to host processor 
30 11 via peripheral controller 20. As usual, peripheral controller 20 is packaged with the optical disk drive. Amag- 
neto-optic record disk 30 is removeably mounted for rotation on spindle 31 by motor 32. A usual disk cartridge 
receiver (not shown) is in operative relation to spindle 31 for inserting and ejecting magneto optical or other 
optical disks 30 into and from drive 21 . Optical portion 33 of drive 21 is mounted on frame.35. A headarm car- 
riage 34 nrK>ves radially of disk 30 for carrying an objective lens 45 from track to track. Aframe 35 of recorder 
35 suitably mounts carriage 34 for reciprocating radial nK>tions. The radial motions of carriage 34 enable access 
to any one of a plurality of concentric tracks or circumventions of a spiral track for recording and recovering 
data on and from the disk. Linear actuator 36 suitably mounted on frame 35, radially moves carriage 34 for 
enabling track accessing. The recorder is suitably attached to one or more host processors 11 , such host proc- 
essors may be control units, personal computers, large system computers, oommunteation systems, Image sig- 
40 nal processors, and the like. Attaching circuits 38 provide the logical and electrical connections between the 
optical recorder and peripheral controller 20. 

Device microprocessor 40 controls device 21 including the attachment circuits connected to peripheral con- 
troller 20. Control data, status data, commands and the like are exchanged between attaching circuits 38 and 
device microprocessor 40 via bkJirectional bus 43. Included in micro-processor 40 is a program or microcode- 
's storing, read-only memory (ROM) 41 and a data and conbxil signal storing randonvaccess memory (f^AM) 42. 
Theoptics of the recorder(drive or devtee) 21 include an objective orfocusing lens 45 nr>ounted for focusing 
and radial tracking n>otions on headarm 33 by fine actuator 46. This actuator includes mechanisms for nrK>ving 
lens 45 toward and away from disk 30 for focusing and for redial nniovements parallel to carriage 34 motions; 
for exanuHe, for changing tracks within a range of 100 tracks so that carriage 34 need not t>e actuated each 
50 time a track adjacent to a track currently being accessed is to be accessed. Numeral 47 denotes a two-way 
light path between lens 45 and disk 30. 

In magneto-optic recording, magnetic bias field generating coil 48. In a constructed embodiment electro- 
magnet provides a weak magnetic steering or bias field for directing the remnant magnetization direction of a 
sman spot on disk 30 illuminatBd by laser light from lens 45. The laser light spot heats the illuminated spot on 
5S the record disk to a temperature above the Curie point of the ntagneto-optic layer (not shown, but can be an . 
alloy of rare earth and transitional metals as taught by Chaudhari et al.. USP %949,387). This heating enables 
magnet coil 48 generated bias field to direct the remna nt magnetization to a desired direction of magnetizatkm 
as the spot cods below the Curie point temperature. Magnet col 48 is shown as supplying a bias field oriented 
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in the Vrite" direction, l.e., binary ones recorded on disic 30 normally are "north pole r^inant nwgnetization". 
To erase disk 30, magnet coi 48 supplies a field so the south pole is adjacent disk 30. Magnet coil 48 control 
49 is electrically coupled to magnet coil 48 over line 50 to control the write and erase directions of the coil 48 
generated magnetic fiek). Microprocessor 40 supplies control signals over line 51 to control 49 for effecting 

5 reversal of the bias field magnetic polarity. 

It is necessary to control the radial positton of the beam following path 47 such that a track or drcumvo- 
lution Is faithfully folk>wed and that a desred track or ctrcumvolutton is quk:kiy and predsely accessed. To this 
end, focus and tracking circuits 54 control both the coarse actuator 38 and fine actuator 46. The positioning 
of carriage 34 by actuator 36 is precisely controlled by control s'^nals supplied by circuits 54 over line 55 to 

10 actuator 36. Additk>nally , the fine actuator 46 control by circuits 54 is exercised through control signals traveHing 
to fine actuator 46 over lines 57 and 58, respectively for effecting respective focus and trackfollowlhg and seek- 
ing actk)ns. Sensor 56 senses the relative position of fine actuator 46 to headarm carriage 33 to create a rel- 
ative positton error (RPE) signal. Line 57 consists of two signal conductors, one conductor for carrying a focus 
error signal to circuits 54 and a second conductor for carrying a focus control signal from circuits 54 to the 

IS focus mechanisms in fine actuator 46. 

The focus and tracking positton sensing Is achieved by analyzing laser light reflected from disk 30 over 
path 47. thence through lens 45, through one-half mirror 60 and to be reflected by half-mirror 61 to a so-called 
"quad detector* 62. Quad detector 62 has four photoelements which respectively supply signals on four lines 
collectively denominated by numeral 63 to focus and tracking circuits 54. Aligning one axis of the detector 62 

20 with a track center line, ferackfollowing operattons are enabled. Focusing operationsare achieved by comparing 
the light intensities detected by the four photoelements in the quad detector 6Z Focus and tracking circuits 
54 analyze the signals on lines 83 to control both focus and tracking. 

Recording or writing date onto disk 30 is next descrit>ed. It is assunrmd that magnet 48 is roteted to the 
desired position for recording date. Microprocessor 40 supplies a control signal over line 65 to laser control 66 

25 for indicating that a recording operation is to ensue. This means.that laser 67 is energized by control 66 to emit 
a high-Intensity laser light beam for recordnig: In contrast, for reading, the laser 67 emitted laser light beam is 
a reduced intensity for not heating the laser aiuminated spot on disk 30 above the Curie point Control 66 sup- 
plies its control signal over line 68 to laser 67 and receives a feedback signal over line 69 indk^ating the laser 
67 emitted light intensity. Control 68 adjusts the light intensity to the desired value. Laser 67, a semiconductor 

30 laser, such as a galliunvarsenide diode laser, can be modulated by date signals so the emitted light beam rep- 
resente the date to be recorded by intensity nKKlulation. In this regard, date drcuite 75 Qatar described) supply 
date indicating signals over line 78 to laser 67 for effecting such modulation. This modulated light beam passes 
through polarizer 70 (linearty polarizing the beam), thence through collimating lens 71 toward half mirror 60 
for being reflected toward disk 30 through tens 45. Date circuits 75 are prepared for recording by the micro- 

35 processor 40 supplying suiteble control signals over line 76. Microprocessor 40 in preparing drcuite 75 Is re- 
sponding to commands for recording received from a host processor 11 via atteching cIrcuRs 38. Once date 
drcuits 75 are prepared, date is transferred directiy between peripheral controller 20 and date circuite 75 
through atteching drcuite 38. Date drcuits 75, also andllary circuits (not shown), relating to disk 30 format sig- 
nals, error detection and correction and the like. Crcuits 75. during a read or recovery action, strip the ancillary 

40 signals from the readt)ack signals before supply corrected date signals over bus 77 to peripheral controller 20 
via atteching circuite 38. 

Read ing or recovering date finom disk 30 for transmission to host processor 1 1 requires optical and electrical 
processing of the laser light beam fiiom the disk 30. That portion of the reflected light (which has ite linear po- 
larization from polarizer 70 roteted by disk 30 recording using the Kerr effect) travels atong the two-way light 

45 path 47, through lens 45 and half-mirrore 60 and 61 to the date detection portion 79 of the headarm 33 optics. 
Half-mirror or beam splitter 80 divMes the reftected beam into two equal intensity beams both having the satne 
reflected roteted linear polarization. The half-mirror 80 reflected light travels through a first polarizer 81 which 
is set to pass only that reflected light which was rotated when the remnant magnetization on disk 30 spot being 
accessed has a "north" or binary one indication. This passed tight impinges on photocell 82 for supplying a 

50 suiteble Indicating signal to differential amplifier 85. When the r^lected light was roteted by a "south** or erased 
pde d^ection remnant magnetization, then polarizer 81 passes no or very little light resulting In no active signal^ 
being supplied by photocell 62. The opposite operation occurs by polarizer 83 which passes only "south" roteted 
laser light beam to photocell 84. Photocell 84 supplies ite signal indk:ating ite received laser light to the second 
Input of differential amplifier 85. The ampirier 85 supplies the resulting deference signd (date representing) 

ss to date drouits 75 for detection. This detection, in the illustrated embodiment, does not include digital demod- 
. ulation (decoding the read back signals from a 1-7 d-k code to date in a host processor format). The detected 
signals indude not only date that is recorded t>ut also all of the so-called andllary* signals as welt. The term 
"date" as used herein is intended to indude any and all information-bearing signals, pr^erably of the digital 
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or discrete value type. 

The rotational position and rotational speed of spindle 31 is served by a suitatde tachometer or emitter 
sensor 90. Sensor 90, preferably of the optical-sensing type that senses dark and light spots on a tachometer 
wheel (not shown) of spindle 31, supplies the nach" signals (digital signals) to RPS circuit 91 which detects 
5 the rotational position of spindle 31 and supplies rotational information- bearing signals to microprocessor 40. 
Microprocessor 40 employs such rotational signals for controlling access to data storing segments on disk 30 
as is widely practiced in the magnetic data storing disks. Addittonally, the sensor 90 signals also travel to spindle 
speed control circuits 93 for controlling motor 32 to rotate spindle 31 at a constant rotational speed. Control 93 
may include a crystal-controlled oscillator for controlling motor 32 speed, as is well known. Microprocessor 40 
10 supplies control signals over line 94 to control 93 in the usual manner. 

Peripheral controller 20 is shown in Fig. 5 This oontroDer includes the compresskHi-deoompressbn mech- 
anism for In-line or real time data compression-decompression. A connectk>n between host processor 11 and 
peripheral controller 20 is effected by a SCSI module 100 that implements the known small computer system 
interface. An 10 data buffer 1 03(dynamically allocated into input data tHiffers and output data buffers using ^. 
IS known technk)ues) temporarfly stores data received from or to be transmitted to the host processor 1 1 . An Opt- 
k:al Disk Controller (ODC) 104 manages the reading and writing of the data to the disk 30 (Fig.4). Error Cor- 
rection Control (ECC) module 106 detects and corrects errors in data being read and generates ECC error 
detection and correctk)n redundancy characters to be written to the nnedium with the data. Run Length Limited 
(RLL) (mod-demod) encoding and decoding is performed in data circuits 75 (Fig. 4). Such mod-demod encodes 
20 and decodes recorded data patterns, such as used in the known 1-7 d-k code. Mk^oprooessor 1 07 (plus control 
store 108 and dynamic store 109) controls the various elements of the controller 20. A Compresston/Deconv 
pression (CD) nrxxiule 101 , such as an integrated cercuit referred to by Shah et al, supra, mnpiements the cofT>- 
pression algorithms. CD nrH>dule 101 includes auton^tic circuit timing and control, as is known, to control data 
flow through peripheral controller 20 under supervision of microprocessor 1 07. This compression-decompres- 
25 slon is in real time (in-line) with the data transfer. Busses 102, llOand 111 interconnect the modules, as shown. 
Controller 20 is preferably packaged with a devtee 21 on a convnon frante. 

Fig. 6 illustrates compression of several data blocks into one group of compressed data blocks recorded 
in a number of data storing sectors 1 1 8 of track 1 1 7 of disk 30. A group 1 1 5 of a plurality of data blocks 1 1 6 is 
selected for recording as described with respect to Fig. 1 . Group 11 5 of compressed data blocks Is transmitted 
30 to controller 20 by host processor 11 . CD 101 in controller 20 compresses group 11 5 sufficiently to be recorded 
as a group of compressed data blocks in sectors 118 plus about one-half of sector 119. The remaining half of 
last sector 119 is filled with padding bytes, as is known. Numeral 122 indicates a sector that was allocated 
previously. Numeral 123 indk:ates a nextsector(s) that were initially allocated according to the above-described 
f BTst methodology. The linked response of controller 20 to the writa-compress command indicates to host proo- 
fs essor 11 that sector(s) 123 are to be dealk>cated as such sectors did not receive any of the data from group 
115. Host processor 11 responds to controller 20 to deallocate sectors 123. 

The above descriptksn assumes that host processor 11 is performing data space managemenL This ar- 
rangement is usual. It is to be pointed out that in a multhhost arrangement.of sharing device 21 that one of 
the hosts may be designated to perform space management Also, In some systems the peripheral controller 
40 perfornts data storage space managemenL 

Fig. 7 aiustrates In abbreviated form three commands for use in a known SCSI interface. WRITE command 
130 includes the operation code field 131 that indicates the command is a WRITE command. LBA address 
fieki 132 indicates the first LBA address that data being transmitted in accordance with the instant WRITE 
command is to begin (the lowest LBA address of possibly several LBA addresses required to be used In storing 
45 data into a plurality ofdisk 30 sectors). Reld 133indicatesthe.numberofunitsofdatathataretobetransferrBd 
from host processor 11 to device 21 for storage on disk 30. One unit is that data storable in one sector of the 
disk 30. FBA disks may have different data storing capacity sectors, such as 512, 1 024 (1 kb). 2048, or 40S6 
bytes of data Field 134 indicates whether or not the data to be transmitted is to be compressed. Field 135 
indicates that this WRITE command is linked to read buffer command 140. This command linkage requires 
so peripheral controller 20 to report to host processor 11 the details of the data storage, i.e. numt>er of sectors 
acto^ly used, the data that enables host processor 11 to buiki an entry forthe later described Rg. 8A illustrated 
fie directory, and kientif ies the sectors to be deallocated. It is noted that LBA 23 is updated in host processor 
11 with a copy thereof recorded in a sector of disk 30. Also, a copy of the Fig. 8A Olustrated file directory is 
recorded on disk 30, preferably in a uncompressed form at a first LBA 23 logk^cd address that immediately pre- 
ss cedes the first LBA address for storing compressed dato. - 

Read buffer SCSI command 1 40 includes operation code field 141 that indk:ates the command is a READ 
BUFFER command. Controller 20 responds to receipt of a READ BUFFER convnand to transfer data from an 
output register(s) of lO buffer 1 03. Controller 20 stores the informatton relating to storing a groupof compiessed 
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data blocks in such output buffer 103 registers) in preparation to respond to the READ BUFFER conrmand 
linked to the WRITE command 130. Reld 142 indicates to controller 20 the number of sectors used to store 
the compressed data blocks. That Is, host processor 11 knows the number of disk sectors required for storing 
the compressed data blocks, hence the new entry for the Fig. 8A illustrated f 3e directory. 

READ DATA command 145 has operatton code field 146 having an indicatk)n that the command is a READ 
DATA command. The first LBA address to be used for transferring data from disk 30 to host processor 11 is 
indicated in field 1 47. Field 148 Indicates the number (n) of data blocks requested or commanded to be trans- 
ferred from the FBA disk to the host processor 11 . Reld 149 indicates to controller 20 the number (N) of disk 
sectors that are to be read. Reld 150 indicates that decompress s either on or off. Link on bit 151 is usually 
reset to be Inactive. For reading one group of compressed data blocks, controller 20 reads the indicated number 
(N) of sectors, decompresses the data blocks, then transfers the decompressed data blocks to host processor 
11 . Controller 20 counts the number of dato blocks transferred such that when the indk»ted number n of f ieki 
148 Is reached, the data transfer is terminated. The data block counting is also used as an integrity check. 

The Fig. 8A Illustrated f ae directory can indicate different levels of detea, the selected level is application 
dependent Every f He that has dato blocks recorded in groups of compressed dato blocks has a separate por- 
tion of the directory respectively indk»ted by numerals 161, 162 and 163 U>r three different date files. Each 
row 160 of each directory represents one entry. A first entry in each directory include in column 164 the file- 
name of the f ae and the LBA address at which the directory is recorded on disk 30. Column 1 65 In the first or 
top most entry indicates the number of dato blocks in each date transfer unrL The term date transfer unit (DTU) 
indicates that a given number of dato blocks are to be transferred between disk 30 and host processor 11 during 
each date transfer. The remaining ento'es 160 are respediveiy for the transmitted and recorded groups of conv 
pressed date blocks. Again, column 164 in the respective entries indicates the first LBA address used to store 
the group. Column 165 indk»tes the number of dato blocks recorded and the number of sectors used to store 
the respective groups of compressed dato blocks on disk 30. Once all of the dato blocks are compressed in a 
single dato compress operatton, the group of compressed date blocks are a continuum of dato with no external 
indication of the dato block boundaries. The decompression mechanism and associated controls klentify the 
date block boundaries after decompressk>n, as is known. 

In addition to the inforn^tion conteined in the Fig. 8A illustrated file directory, additional deteas of each 
group may be provided. In such an alternate implementation of the fBe directory, controller 20 retorns, in ad- 
dition, for each group of compressed dato btocks 0-e. for each respective entry of the Fig. 8A illustrated file 
directory) a map of the relation of data blocks and data storing sectors (uses the LBA togical address, not the 
actual physk:al location on disk 30) for each of the groups. This additional Information Is used by the host to 
manage the recorded date and unused disk 30 sectors indicated in LBA 23. 

All ento'es conteln the above indicated mapping of date blocks to LBA addresses for each and every group 
(Gp.) of compressed dato btocks in the current file. That is, each date block b indteated as being recorded in 
one or more sectors, depending on the compression and size of the date blcxdcs. Several compressed dato 
blocks may be recorded in one sector. In this instance, the LBA addresses are the same for starting and ending, 
i.e. LBAio to LBAio for example could occur for several dato blocks. 

A format of the Fig. 8A Olustrated directory using the additional addressing Information is set forth below. 


First entry 

Filename 

Number of data blocks in a data transfer unit 

Second entry 

Gp. 1 LBA 

Number of data blocks and sectore in this group 


data btock n 

LBANatbyteB 


data bkick n^l 

LBANatbyteB2 


data block n'*2 

LBANsatbyteB^ 


50 


(Map of ail date blocks in group (Gp.) 1 continues, term "byte" indicates byte displacement of the respective 
compressed dato block as recorded in a sector.) 


Third entry 


Gp. 2 LBA 


Number of data blocks and sectors 


55 (Map of data blocks to LBA addresses is set forth at>ove) 

The super scripte merely indicate 1st (no super script), second, eto byte positions of the respective triocks 
n. n+1,n+2etc. 

The above described directory structores enat)le the date contente of a single group of compressed data 
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blocks to be updated without the necessity of reading and then rewriting the entire f Oe. An update of a group 
of compressed data block only requires the reading of one group of compressed data blocks. The update group 
of compressed data blocks may require more sectors for storage than that use to store the previous generation 
group of compressed data blocks. That is additional sectors have to be allocated. Since it Is desired that each 

5 group of compressed data blocks are recorded in contiguous sectors (except of unaddressable intervening de- 
fective sectors), a new allocation may t>e required. All of this activity is explained later with respect to Rg. 1 5. 
Host processor 11 uses this Information to determine the next available set of contiguous LBA addresses that 
have sufficient number of addresses (sectore) for storing the updated group of compressed data t>locks. 
For WORM (write once, read many) optical disks, the host processor may issue a MEDIUM SCAN conv 

10 mand to locate the next available LBA addressed sector for storing the updated group of compressed data 
blocks. Host processor 11 saves this informatton in an expanded directory entry for use when the data are to 
be retrieved or read. 

As later described with respect to Fig. 10» another control parameter Is a mininmim or maximum number 
of sectors to be used in the CKD and ECKD examples for practicing the present invention. The number N of 

15 sectore requred to store the uncompressed data is compared with a MIN (minimum value) and a MAX (max- 
imum value), if the number of requfred sectore is between the MIN and MAX values, then a DTU Is made using 
the number N. MIN ensures a reasonable usage of disk storage space while MAX ensures a reasonable access 
to compressed data blocks. If N Is greater than MAX, t hen N Is made equal to MAX. If N Is less than MIN. then 
N is made equal to MIN. The number of data bytes in a DTU is N*SB (SB is number of bytes storable in one 

20 sector) for FBA devices and N*DB (DB is number of data bytes desired for storing one data block) for CKD 
and ECKD devices. The number of bytes in a DTU Is stored in the f frst or top entry 160 (Fig. 8/^ of each file 
directory. As one variation, field 166 in each of the entries 160 contains a compress DTU indicating bit C. If C 
is unity, then the data represented by the respective entry 160 are recorded in a compressed form. If bit C is 
zero or nil, then the data are recorded on disk 30 without data compression. The compressed bit C may also 

25 be recorded in each and every sector storing data in accordance with the present invention. 

Fig. 8B dlagrammatb^ly aiustrates format of a disk sector of an FBA disk. Sector 170 is in track 169 of 
disk 30. Intersector gap 171 separates sector 170 from an immediately preceding sector (not shown). Sector 
ID 172 is an embossed area that contains the track and sector address of sector 170. Ihtrasector gap 173 se|>- 
arates the hard sectored or embossed mark 172 from the magneto-optically recorded portion that constitutes 

30 the remainder of sector 170. Data synchronization signals DATA SYNC 174 are magneto-optjcally recorded 
with the data stored In portk>n 175 of sector 170. Confat)! area 176 stores magnetcMiptically recorded control 
signals, as may be desired. A compress bit CI 77 (considered a part of the control signals in area 176) if set 
to unity indk:ates that the data in portion 175 are compress. If C 1 77 is set to zero or nil, then the data stored 
In portion 1 75 are not compressed. Sector 1 70 ends with the error detection and correction redundancy in ECC 

35 1 78 portion. ECC 178 stored signals are generated and stored in a known manner that Is not pertinent to an 
underetanding of the present mvention. Intersector gap 179 separates sector 170from a n^ succeeding sector 
180. It is preferred that compress bit 177 be used while practicing the present Invention. 

Fig. 9 is a flow chart showing a sequence of machine operations for storing a file in a plurality of groups 
of compressed data blocks wherein each group Is separately transmitted from a host processor to a data storage 

40 system as a DTU having a number of uncompressed bytes as set forth above. At step 185 the data to be re- 
corded is analyzed fbr determining the number of DTU's to be generated. The actual size In bytes/data blocks 
of a DTU nnay be different from fOe to file. In step 186, the DTU size is nrKxlified to accommodate the numt>er 
of data blocks to be initially recorded for equalizing the sizes of a plurality of DTU's to be used. For example, 
if the number of data blocks to be compressed and recorded is less than two desired DTU*s and one half of 

45 the number of date blocks resulte in a number of date bytes greater than MIN, then two DTU's each having 
one-half of the date blocks are created. This same principle is applied to transfierring date btocks having any 
number of DTU's except for updating a recorded group of compressed date blocks, as wilt become apparent 
If the DTU sizes cannot be equalized, then a last DTU may have a number of bytes less than the MIN (minimum) 
number of bytes. Upon updating the recorded giroup of compressed date blocks resulting from a small last DTU, 

50 a DTli Is generated that adds a number of date blocks to make the size of the DTU, hence group of compressed 
date blocks, larger to meet the DTU size requiremente set forth with respect to Fig's 9 and 11. Fig. 15 relating - 
to updating a recorded group of compressed date blocks illustrates machine steps for storing an updated DTU 
that Is too targe for the current altocated date storage space for a recorded group of compressed date blocks 
resulting from compressing and storing the updated DTU. 

55 At *GET DTU* step 1 88 (Rg. 9), a DTU of date blocks built for date transfer. Step 189 transfers the DTU 
to date storage system 12. Date storage system 12 compresses and stores the transferred DTU as described 
earlier. At step 190, host processor 11 ascerteins whether another DTU is to be transferred. If not (DONE = 
1), then host processor 11 exite for performing other work not related to precticing the present invention. Other- 
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wise, steps 188 and 189 are repeated until ail DTU*s liave t>een transmitted to data storage unit 12. 

Fig. 10 is a flow chart showing selecting a MIN and a MAX value respectively for image (non-coded or 
graphics) data and text (coded) data. The compressibSity of data is a measure for selecting MIN and MAX. In 
this regard, each f De of image or text data may compress sut>stantial)y different from data from other files as 

5 well as changing from data block to data block in either type of data. Image or text Once a first group of data 
blocks have been compressed and recorded as a group of compressed data blocks, the compresision ratto may 
be recorded In the Fig. 8A illustrated fQe directory as a reference for subsequent compression and storage of 
data t>iocks. The Fig. 1 0 illustration assumes that the omage data has been compressed 75% (compressed inrv 
age data blocks are 25% of original size) and text data blocks have been compressed about 50%. These nr>eas- 

10 ured values may be changed for calculation purposes for adding a margin of error accommodation into the 
calculatk)ns. 

Step 195 determines whether the data in the file is text or image. If image, step 196 calculates the MIN 
value as 4*SB (bytes in a sector), i.e. at least four sectors are to be used for storing a group of compressed 
data blocks. The numt)er four is selected in an arbitrary manner. Sector size affects the mlninrtum number of 

15 sectors to be used. Step 197 calculates MAX as being 64*SB. in a FBAdisk having 1024 byte sectors, then 
the maxinmim DTU size is 64 KB (KQobytes). Again, system conskJeratkms may change these values. Such 
considerations are beyond the present description. From step 195. for text data (IMAGE DATA= NO), step 200 
calculates MIN as 2*SB while step 201 calculates MAX as 32*SB. The number of uncompressed bytes for inn- 
age data in MIN and MAX is equal to the numt)er of uncompressed bytes for text data. The different compres- 

20 sion ratk>s change MIN and MAX values inversely to the expected compression ratk>. Upon completing either 
calculatkHi, host processor 1 1 stores the MIN and MAX values in the first entry 1 60 (Fig. 8A) of t he appropriate 
file directory and then exits the calculation. 

The MIN and MAX values may also be predetermined and included as parameter data defining a dass of 
data as set forth in Gelb et al US patent number 5.018.060 titled "ALLOCATING DATASTORAGE SPACE OF 

25 PERIPHERAL DATA STORAGE DEVICES USING IMPUED ALLOCATION BASED ON USER PARAME- 
TERS". Gelb et al teach that data set parameters implicitly control peripheral data storage operattons. Such 
implicit control based on data base or file parameter data may be applied to practicing the present invention. 

Fig. 11 showsexecutionofaWRITEcommand by data storage system 12wherein the data blocks received 
in on DTU are compressed then recorded as a group of compressed data blocks. Step 210 receives a WRITE 

30 command 1 30. Step 211 sets the link commanded in field 135 for reporting the actual number of sectors used 
to store the resultant group of compressed data tHocks and a oompressbn ratio CR achieved. Step 212 sets 
a compress nxxJe in data storage system 1 2 for acth/ating CD 101 to compress the data blocks being received 
into one continuum of compressed data. Step 213 receives, compresses and stores the DTU data blocks. Step 
216 compares the numt>er of sectors actually used to store the compressed data with the number of sectors 

35 initially allocated. Step 217 compares the byte count of the original data bk>cks in the received DTU with the 
byte count of the compressed data blocks. In most instances, the t^ count of the compressed data blocks 
will be less than the byte count of the original DTU data blocks. In this instance, at step 21 8, data storage sys- 
tem 12 indicates to host processor 11 that the data storage operation has been completed. The identificatibn 
of any unused sectors plus other informatk>n describing the just-completed data recording operation Is to be 

40 transferred from data storage system 12 to host processor 11 . This transfer is effected by host processor 11 
responding to the indicatton of a completed recording operation by issuing a READ BUFFER comnrumd 140 
to data storage system 12 to send the number of unused altocated sectors and all other compression infor- 
nruitk>n to tiost processor 11 . Host processor 1 2 in step 21 9 responds to the indicatran of unused allocated sec- 
tors to deallocate such sectors for use in storing other data. Note that if the compress bit 134 is off, then no 

45 oompresskm occurs. 

If at step 217, It is detiermined that the data compression resulted more data bytes In the compressed data 
blocks than were in the original data blocks, then the data blocks wil be recorded without data compressk>n. 
This growth in size of the compressed data blocks may occur when the original data blocks have certain data 
patterns. In any event, at step 220, data storage system 1 2 sends a channel command retry (CCR) or its equiv- 

so alent to host processor 11. CCR indicates that the DTU has to be retransmitted by host processor 11 to data 
storage system 12. That is. the increased in size of the DTU after compression is conskJered an error conditk>rk 
The CCR Indicates that a recording error has occurred. Host processor 11 responds to the CCR at step 221 
by resending the DTU to data storage system 11 . At step 222, data storage system 12 stores the DTU without 
data compression. The above-described operatkMis are exited from either step 219 or 222. 

ss Rg. 12isaflowchartshowingsystemoperatk>nsforreadingdata.Hokprocessor11 rn step 225 prepares 

to read data, L.e. Wentifies the data blocks to be read. Host processor 11 then in step 226 searches for a fBe 
directory (Rg. 8A). Such file directory may be read from disk 30. If there is no file directory relating to conv 
pression. then the data are not compressed. Also, if the fieki 166 of the Rg. 8 illustrated directory forthe klefv 
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tif led group is zero, then that group Is not connpressed. Further, if data to be read are compressed and it is 
desired to deconopress in a unit other the storing data storage system 12. step 226 directs host processor op- 
erations to read all identified data without decompression via path 227. From path 227, a usual data recording 
operation not Involving data compression is performed (not shown). Host processor 11 builds issues one READ 

5 command 145 for each of the recorded groups of compressed data blocks to be read. Depending on the desired 
read operation, field 150 or READ command wfll t>e set to indicate either decompress or no decompress OFF. 
Host processor 11 before sending the READ command 145 to data storage system 12 examines field 150 at 
step 226. If host processor 11 at step 226 finds that the data to be read are compressed and decompression 
is desired, then step 230 sets field 150 to compress ON. All of the groups of compressed data blocks having 

10 data blocks to t>e read are identified in step 231 via examination of the appropriate file directory 161-163. Host 
processor 11 in step 232 then builds one or more READ commands 145 for reading the step 231 identified 
groups of compressed data blocks wfth decompressk>n. The term build used above indteates that the appro- 
priate control data are hserted Into a READ command for commanding data storage system 12 to perform a 
desired read. Such command includes the number of LBA addressed sectors to be read as well as the togk^al 

15 address in LBA of a first one of the sectors. One READ comn^and Is sent by host processor 11 to data storage 
system 12 in step 232, there can be a number of READ commands sent for fetching a plurality of groups of 
record blocks. Data storage system 12 receives the READ command. At step 233, data storage system checks 
the sector compress bitof the first sector storing the requested group to be read. If bitC 177 (Fig. 8B) is unity, 
then the data are compressed. Data storage system 12 then in step 234 reads the requested group including 

20 decompressing the data. It is to be noted, that if the READ command field 150 indicates decompresston is 
OFF, then no decompresston occurs even if bit CI 77 is set to unfty. On the other hand, if bit C 1 77 equals 
zero (data In the sector are not compressed), the at step 235 data storage system 12 reads and sends the 
read data without decompression to host processor 11. The Fig. 2 illustrated system exits the read operation 
for one group from either step 234 or 235. 

25 Fig. 1 3 illustrates operation of data storage system responding to a READ command 1 45: Step 236 receives 

the READ command. Step 237 checks the compress field 1 50. If the compress field indicates that decompress 
is ON, then C bit 177 of the sector being accessed is checked to ensure that the data to be read is in fact 
recorded and stored in a compressed form. Step 238 executes the READ command by decompressing the 
data being read if field 150 indicates compressksn and C bit 177 is ON. If the field 1 50 indicates decompresston 

30 if OFF. the data stored In the addressed sectors are transferred without decompression whether compressed 
or not That is. In all cases, data storage system 12 Iransfere the data without decompresston if fieM 150 indi- 
cates compress is OFF. This control enables transferring data in either compressed or decompressed form. 

Fig. 14 illustrates one applicatk>n of the inventk>n in a system having linked host processors. Both batch 
and in line data compressk>n/decompression are employed. Compression-decompressk)n software modules 

35 251 and 273 provide batch data compressk>n and decompression while integrated circuit chips (hardware com- 
press decompress) 253 and 272 provkie in line (real time) data compresston-decompression Two data proc- 
essing systems 240 and 241 are linked by data link 263. Link 263 may be a local area network (LAN), a data 
comnrHjnk:atk)n circuit or transfer of a rerTK>vat>le data cartndge nrvanually or via a library, mail etc between the 
two data processing systems. Host processor 250 in system 240 has a software compress-decompress facSity 

40 251 , a transfer link facility 252 that involves no compresston or decompression and an in-line hardware conv 
press-deoompress facQity 253. Facilities 251-253 may be physically located in data processing system 240 in 
host processor 250 or as a part of a channel connection ttiat includes logic switch 254 (prograrrvned or tiard- 
ware) connecting host processor 250 to facilities 251-253. Dashed line 255 indicates that switch 254 is pro- 
grammingly controlled by host processor 250. Agiven data processing system may have only 1) batch compress 

45 fadlity 251 and link fadlty 252. 2) in-line facQity 253 and link facflity 252, 3) all fectlities 251-253 or 4) efther 
fadlity 251 or 253 may be located either in data storage system 262 or data link 263. 

The input-output (lO) connections from facilities 251-253 are effected by logic switch 260 that Is progranrv 
mingiy controlled by host processor 250 as indicated by dashed line 261. Switch 260 directs lO data flow be- 
tween factlities 251-253 and a data storage system 262 or data line 263. 

50 Data processing system 241 is shown as being identical to data processing system 240. Data processing 
system 241 includes host processor 270 that tnay have a different computational arrangement and capability 
from host processor 250. logic switch 271 , facfllties 272-274. data storage system 275 and switch 277 that se- 
lectively connects data processing system 241 to data link 263 to other systems and data processing system 
240. 

55 Pig. 15 illustrates updating a recorded group of compressed data bk^cks. Host processor 11 iri step 280 
has updated data blocks and desires to update a f Oe recorded In data storage system 12 as a plurality of groups 
of compressed data t>locks. Step 281 compares the data length (number of uncompressed data bytes) of the 
updating DTU with the riumber of bytes in sectors currentiy recorded as one group to be updated. Host proc- 
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essor 11 also examines the number of padding bytes in a last sector storing compressed data for estimating 
whether or not the updated data l>locks are storat>le in the currently allocated sectors for the group(s) to t>e 
updated. 

At step 282 host processor 11 determines whether or not the updating DTU can be stored in currently al- 

5 located sectors or if more or different sectors should be allocated. That Is, if the updating DTU has more data 
bytes than the currently recorded group, then additional sectors are aOocated at step 288 (host processor 11 
does the allocation). Such new sectors are preferably contiguous sectors that may not tndude any sectors con- 
taining the recorded group of data blocks to be updated. Following allocation step 288, the updating DTU is 
recorded at step 289. Then, host processor 11 at step 290 deallocates the sectors containing the group of data 

10 blocks to be updated. The Fig. 2 Olustrated system then exits the updating operation from step 290. 

if, at step 282, the number of data bytes In the updating DTU is substantially equal to the number of bytes 
(uncompressed) of the recorded DTU. then the updating occurs at step 283 using the sectors currentiy storing 
the group to be updated. The Fig. 2 illustrated system then performs step 290 before exiting the updating op- 
eration. If the updating DTU has fewer bytes than the recorded group, then the updating DTU is recorded in 

IS sectors selected from the sectors containing the group to be updated. The sectors not used to record the up- 
dating DTU are deallocated at step 290. 

It may be deckled that, independenfly of any data growth patterns, to always store the updated data blocks 
in a newly allocated s^ of sectors and to deallocate or free the sectors storing the current group(s) of com- 
pressed data blocks to be updated. In this situation, steps 288-290 are performed. For exanr^le, if there is a 

20 desire to save the original group(s) of compressed data blocks, such original recording may be retained. Host 
processor 11 then updates the appropriate file directory 160-162 and ^its the storage operation. 

In the updating operation shown in Fig. 1 5, whenever the compressed data has more bytes than the orig- 
inal uncompressed data, the data are recorded In an uncompressed form. The steps shown in Rg. 1 1 are added 
to the Rg. 1 5 fliustrated sequence. 

25 

Claims 

1. Apparatus for storing data in compressed form in a data storage device having a plurality of addressable 
30 like-sized data storage areas, each for recording a predetermined number of data bytes, the data storage 

device being connected to means for receiving data to be recorded, said received data being arranged In 
a plurality of addressable data blocks, characterised in that the apparatus comprises, in combination: 

selection means in the means for recehring data for selecting one or ntore data transfer units of 
data blocks to be recorded, each saki transfer unit of data blocks having, a given numt>er of data bytes 
35 and including one or more of said addressatrfe data blocks; 

compresskxi means connected to the selection means for compressing sakI transfer unit of data 
bfocks to be recorded as a group of compressed data t>locks; 

data access means in the device connected to said compression means for recording sakI group 
of compressed data blocks in said addressable data storage areas as one continuum of compressed data; 
40 and 

directory means indicating whk:h ones of said addressable data storage areas sakI continuum of 
data is recorded in, and indicating that siakl continuum of data contains sakI selected transfer unit of data 
bfocks in a compressed form. 

45 2. Apparatus according to daim 1 including: 

allocatfon nneans connected to the selection means for responding to the number of data bytes In 
each said transfer unit of data blocks to indicate that saki transfer unit requires a first numt)er of sakI ad- 
dressable data storage areas to record said transfer unit of data blocks; and 

recording means for recording sakI transfer unit as a group of compressed data blocks in a second 
so number of said addressable data storage areas, said second number being equal to or less than said first 

number. 

3. Apparatos according to daim 2 indudlng update means connected to said selection means and to sakI 
allocation means for updating a recorded group of compressed data blocks with updated data blocks, in- 
55 duding receiving updated ones of said data blocks and selecting a data transfer unit of data blocks to tn- 

dude saM updated data bkicks; sakI update means being connected to said allocation means for allocating 
a number of said addressat)le date storage areas for receiving and recording sakl updated.compressed . 
data blocks and for deallocating ones of saki allocated addressable date storage ^eas In whk:h are stored 
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the original group of compressed data blocks to be updated. 

Apparatus according to any one of claims 1 to 3 wherein the selection means Is connected to the data 
storage device for selecting said gh^en number of data bytes to form a transfer unit in dependence on the 
number of data bytes which are recordable In each of said data storage areas. 

Apparatus according to any one of claims 1 to 4, including range means indicating a range of number of 
bytes to be used fer transferring data blocks between said means for receiving data and said data storage 
device, wherein sakJ selection means Is connected to said range means for receh^ing said range indication 
and responding to the received range indicatton for selecting a predetermined number of saM data blocks 
to be a data transfer unit and to be in one of said groups of data blocks such that each said group of data 
blocks has a number of data bytes equivalent to a plurality of uncompressed data blocks. 

Apparatus according to any one of claims 1 to 5 wherein the apparatus includes: 
CKD means for supplying a plurality of CKD data t>locks; 

a CKD formatted disk within the data storage device for receiving and recording CKD data; 

said selection means being connected to saki CKD means fbr receiving and selecting a predeter- 
mined number of said CKD data blocks as a data transfer unit of sakJ CKD data blocks; 

said data access means having CKD recording means for recording sakl transfer unit of CKD data 
as compressed by said compression means as a single record on sakI CKD formatted disk; and 

repeat means connected to saM selection nteans and to said CKD means for repeatedly actuating 
the CKD means to supply a transfer unit of CKD data blocks for compression and recording In respective 
single CKD records. 

Apparatus according to any one of claims 1 to 5, including: 

a host processor connected to a peripheral controller, said data storage device being connected to 
said peripheral controller; 

an FBA sectored disk in said data storage device having a pluraltty of addressable sectors for re- 
ceiving and recording data blocks; 

said selection n>eans having means for selecting said data blocks for said data transfer unit to be 
recorded in a predetermined number of sectora on sakJ FBA sectored disk; and 

repeat means connected to sak) selection means for repeatedly actuating the selection means for 
selecting a plurality of said transfer units of data blocks from one file of such data t>locks fbr compression 
and recording of sakl transfer units of data blocks such that said file of data bk>cks is recorded in com- 
pressed form on said FBA sectored disk in a plurality of said continuum of data wherein each sakl continua 
consista of one sakl group of compressed data blocks. 

Apparatos according to any one of the preceding clatrrts, including data recording management means 
connected to said directory means and to said data access means for actuating the directory means to 
establish a plurality of said file directories, one file directory for each file of data recorded in compressed 
form; sakl recording management means actoating sakl directory means to record In each of sakl f Oe di- 
rectories a number of sakl data blocks to be included in each of sakl data transfer unite of data and in- 
cluding recording a maximum number of bytes to be included in any one of said data transfer unite. 

A method of compressing and recording onto a date storage medium data of a file which is arranged in 
a plurality of addressable data blocks, the method comprising the steps of: 

selecting a plurality of sakl date blocks of sakl file to be compressed and recorded; 

segmenting the selected plurality of addressable data blocks into one or more data transfer unite; 

compressing each of said one or more data transfer units and recording them as respective sep- 
arate groups of compressed data blocks; and 

creating and maintaining a file directory indicatiiig the address and size of each of said recorded 
groups for enabling random access to recorded data within sakl file of date blocks. 

A method according to daim 9 including the steps of: 

before recording one of said groups of compressed date blocks, allocating a first numt>er of ad- 
dressable data storage areas of the storage medium for recording saki one group of compressed data 
bk>cks;and 

after recording said one group of compressed date blocks, deallocating allocated addressatrfe diata 
storage areas, If any, irito which said one group of compressed data blocks was not recorded. 
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11. A method according to daim 9 or claim 10, including: 

supplying CKD formatted data blocks of one CKD formatted file and selecting said CKD data blocks 
to be compressed and recorded; 

compressing one or more data transfer units of said CKD data blocks into one or more groups, re- 
5 spectively. of compressed CKD data blocks; and 

recording the one or more groups of compressed CKD data blocks as one record on a CKD for- 
matted record member. 

12. A method according to daim 9 or daim 10, induding: 

io selecting an FBA forrnatted record medium to be said record medium, said FBAformatted record 

medium having a plurality of addressable data-storing sectors, each data-storing sector being capable of 
recording a given number of data bytes; and 

selecting saki date transfer unit to have a first predetermined number of said data blocks having 
a number of uncompressed data bytes equal to a data storage capadty, in data bytes, of a second pre- 

f 5 determined number of said data-storing sectors. 

13. A method according to any one of daims 9 to 12, induding: 

setting a range of number of bytes to t>e induded in each of said data transfer units; and 
selecting a number of said data blocks such that a number of data bytes in the selected number 
of date blocks is within the set range. 
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